//
// Created by francklinson on 2021/5/6.
//

/*你现在是一场采用特殊赛制棒球比赛的记录员。这场比赛由若干回合组成，过去几回合的得分可能会影响以后几回合的得分。

比赛开始时，记录是空白的。你会得到一个记录操作的字符串列表 ops，其中 ops[i] 是你需要记录的第 i 项操作，ops 遵循下述规则：

整数 x - 表示本回合新获得分数 x
"+" - 表示本回合新获得的得分是前两次得分的总和。题目数据保证记录此操作时前面总是存在两个有效的分数。
"D" - 表示本回合新获得的得分是前一次得分的两倍。题目数据保证记录此操作时前面总是存在一个有效的分数。
"C" - 表示前一次得分无效，将其从记录中移除。题目数据保证记录此操作时前面总是存在一个有效的分数。
请你返回记录中所有得分的总和。



示例 1：

输入：ops = ["5","2","C","D","+"]
输出：30
解释：
"5" - 记录加 5 ，记录现在是 [5]
"2" - 记录加 2 ，记录现在是 [5, 2]
"C" - 使前一次得分的记录无效并将其移除，记录现在是 [5].
"D" - 记录加 2 * 5 = 10 ，记录现在是 [5, 10].
"+" - 记录加 5 + 10 = 15 ，记录现在是 [5, 10, 15].
所有得分的总和 5 + 10 + 15 = 30

来源：力扣（LeetCode）
链接：https://leetcode-cn.com/problems/baseball-game
著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。*/
#include <string>
#include <vector>
#include <iostream>
#include <stack>

using namespace std;

class Solution {
public:
    int calPoints(vector<string> &ops) {
        stack<int> s;
        for (const auto &x: ops) {
            if (x == "C") {
                s.pop();
            } else if (x == "+") {
                // 取顶部两个数进行加和
                int temp = s.top();
                s.pop();
                int temp2 = s.top();
                s.pop();
                s.push(temp2);
                s.push(temp);
                s.push(temp+temp2);
            }
            else if (x == "D"){
                s.push(s.top()*2);
            }
            else
                s.push(stoi(x)); // string 先转int  后面就不需要stoi 和 to_string
        }
        int sum = 0;
        while (!s.empty()){
            sum += s.top();
            s.pop();
        }
        return sum;
    }

};


int main() {
    vector<string> v{"5", "2", "C", "D", "+"};
    Solution sol;
    cout << sol.calPoints(v) << endl;
    return 0;
}